草庐IT

Java 对象和类

全部标签

javascript - 了解一下 ember/ember-data 对象的生命周期如何。或者调试 Ember.js 和 Ember-Data 的技巧/提示?

我不是在寻找如何调试javascript。我对手头的工具非常熟悉,尽管不熟悉Firefox的新调试功能,因为他们构建了自己的“firebug”。我真的只是在寻找一种简单的方法来读取堆栈跟踪,因为对象/函数很容易通过Ember自己的调用机制运行。很容易忘记被调用的函数是什么以及它附加到的this的绑定(bind)。有没有人在调试ember的堆栈时想到了任何技巧或肺炎?更新:这不是异步调试的问题http://www.html5rocks.com/en/tutorials/developertools/async-call-stack/ 最佳答案

javascript - 使用 for/in 循环 javascript 显示对象属性

这个问题在这里已经有了答案:HowdoIloopthroughorenumerateaJavaScriptobject?(48个回答)关闭9年前。下面是一个简单的示例,我想使用for/in循环显示对象属性varObject={x:1,y:2,z:3};for(propertyinObject){console.log(Object.property);};它显示未定义。但如果使用console.log(Object[property]);它会工作,并显示123为什么我不能使用Object.property在for/in循环中显示?

javascript - 如何在 underscore.js 中获取数组对象键的总和?

我有以下数组:varitems=[{price1:100,price2:200,price3:150},{price1:10,price2:50},{price1:20,price2:20,price3:13},]我需要获取包含所有键总和的对象,如下所示:varresult={price1:130,price2:270,price3:163};我知道我可能只使用循环,但我正在寻找下划线样式的方法:) 最佳答案 不是很漂亮,但我认为最快的方法是这样做_(items).reduce(function(acc,obj){_(obj).ea

javascript - javascript中对象的笛卡尔积

我需要根据N个属性的列表生成一组完整的变体,同时保持属性名称不变。varinput=[{'colour':['red','green']},{'material':['cotton','wool','silk']},{'shape':['round','square','rectangle']}];varexpected=[{'colour':'red','material':'cotton','shape':'round'},{'colour':'red','material':'cotton','shape':'square'},{'colour':'red','material'

javascript - 如何迭代对象原型(prototype)的属性

我有一些代码:varobj=function(){};//functionalobjectobj.foo='foo';obj.prototype.bar='bar';for(varpropinobj){console.log(prop);}令我惊讶的是,所有记录的都是foo。我希望for循环也遍历obj原型(prototype)的属性(即bar),因为我没有检查hasOwnProperty。我在这里错过了什么?是否也有一种惯用的方法来遍历原型(prototype)中的所有属性?我在Chrome和IE10中对此进行了测试。提前致谢。 最佳答案

javascript - JSON 对象!= JavaScript 对象?

这个问题在这里已经有了答案:ObjectcomparisoninJavaScript[duplicate](10个答案)关闭9年前。为了方便起见,我编写了一个简单的toJSON原型(prototype),用于处理我认为安全的JSON:String.prototype.toJSON=function(){returnJSON.parse(this.valueOf());};我正在使用它来测试我的网络服务。不幸的是,即使是这个简单的测试:varv0='{"echo":"hello_world"}'.toJSON(),v1={"echo":"hello_world"};失败了:console

javascript - 为什么 JavaScript 原始变量不可变而对象变量不可变?

有一种方法可以在原型(prototype)属性的帮助下将成员函数或成员属性添加到数字、字符串等...-变量:Number.prototype.member=function(){console.log('number-member-functioncalled');};或者在变量本身的原型(prototype)属性的帮助下:varnum=7;num.__proto__.member=function(){console.log('number-member-functioncalled');};就像任何其他类型的JavaScript类型一样。但是,在JavaScript中实现Primi

javascript - 如何仅使用 DOM 对象获取 leaflet.js 实例?

我现在正在构建自定义Knockout.js绑定(bind)来处理多边形的绘制。在这种情况下,KnockoutAPI只给我一个DOM对象的引用,以访问我需要更新的任何内容。然而,看起来leaflet.js的设计是希望用户在他们的实现中存储map实例。我没有那个选项。尝试这个给了我一个错误:varexistingMap=L.map('aMapIDGoesHere')错误是:mapalreadyinitialized。有什么方法可以使用DOM元素或元素ID来访问map实例?根据要求,这是自定义绑定(bind),请注意这是一项正在进行的工作:ko.bindingHandlers.leaflet

javascript - 检查对象在 JavaScript 中是否可序列化的可靠方法

是否有已知的方法或库已经有帮助程序来评估一个对象在JavaScript中是否可序列化?我尝试了以下方法,但它没有涵盖原型(prototype)属性,因此它提供了误报:_.isEqual(obj,JSON.parse(JSON.stringify(obj))还有另一个lodash函数可能会让我更接近真相,_.isPlainObject。然而,当_.isPlainObject(newMyClass())返回false时,_.isPlainObject({x:newMyClass()})返回true,因此需要递归应用。在我自己冒险之前,有没有人知道一种已经可靠的方法来检查JSON.parse

javascript - AngularJS 范围直到在 ui 中执行某些操作后才会更新,比如单击具有函数的对象

当视口(viewport)小于或等于641px时,我试图将类添加到我的侧边栏,并且我必须在这种情况下观察窗口的宽度$scope.$watch(function(){return$window.innerWidth;},function(value){if(value它在第一次加载时登录,但是当我调整大小时,我必须在它再次触发之前进行一些点击。例如。我调整大小,然后单击具有ng-click行为的项目,这是唯一一次,它再次记录。我已经阅读了一些问题,这可能是由于$digest和$apply?谁能解开我的困惑。 最佳答案 需要触发摘要循环